<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        //1.问
        console.log(num);


        //2.问
        console.log(num);//undefined 坑1
        var num = 10;
        //相当于执行了以下代码
        var num;
        console.log(num);
        num=10;


        //3问
        fn();
        function fn() {
            console.log(11);
        }
        //4问
        fun();//报错 坑2
        var fun =function (){
            console.log(22);
        }
        //相当于执行了以下代码
        var fun;
        fun();
        fun =function (){
            console.log(22);
        }

        //1.js引擎运行js分为两步：预解析   代码执行
        //(1)预解析 js引擎会把js里面所有var 还有function 提升到当前作用域的最前面
        //(2)代码执行 按照代码书写顺序从上到下执行
        //2.预解析分为 变量 预解析（变量提升） 和  函数预解析（函数提升）
        //（1）变量提升  把所有变量声明提升到当前作用域最前面 不提升赋值操作
        //(2)函数提升    把所有函数声明提升到当前作用域最前面
        //函数表达式  调用必须写在函数表达式的下面  不调用函数
    </script>
</head>
<body>
    
</body>
</html>